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Рассматривается исчисление рекурсивных предложений для теории структурных функциональных моделей. Исследуются во- 
просы разрешимости и полноты исчисления. Предлагаются стратегия и алгоритм установления выводимости формул исчисле- 
ния, показывается корректность алгоритма и определяется оценка его эффективности. 


Введение 

Рассматривается формальное исчисление, ис- 
пользуемое для установления выводимости пред- 
ложений в рамках теории структурных (С-) функ- 
циональных моделей [1,2]. Проведенные исследо- 
вания традиционно относят к области искусствен- 
ного интеллекта. Прикладной стороной исследова- 
ния является создание интеллектуальных програм- 
мных комплексов широкого класса, опирающихся 
на дедуктивный подход в области менеджмента 
знаний. Термин «знание» здесь имеет ограничен- 
ную трактовку: знания представляются специаль- 
ными строго определенными информационными 
структурами, допускающими автоматизированную 
обработку с использованием аппарата формальной 
логики. Представляемые результаты могут быть ис- 
пользованы при реализации различных информа- 
ционных комплексов, - от экспертных [3] и когни- 
тивных систем [4] до инструментальных и СА8Е- 
оболочек быстрого прототипирования программ 
[5]. 

В первом разделе определяются используемые 
понятия и необходимые соглашения. Во втором 
вводится понятие интерпретации С-модели и фор- 
мулируется исчисление функциональных предло- 
жений для теории структурных моделей [6] , а также 
исследуются некоторые свойства построенного ис- 
числения. Третий раздел посвящен описанию стра- 
тегии и базового алгоритма установления выводи- 
мости предложений языка. Для алгоритма доказы- 
вается свойство корректности, и устанавливаются 
сложностные характеристики. Наконец, в послед- 
нем разделе кратко рассмотрены особенности вве- 
дения рекурсии. 


1. Базовые определения 

Дадим основные определения. Прежде всего, 
зафиксируем сигнатуру X. 

Определение 1. Зафиксируем Х=(А,Р,Р,Б), где А, 
Р, Р и О - не более чем счетные множества (эл- 
ементарных) имен объектов, функциональных 
символов, селекторных символов и имен схем, со- 
ответственно. Выделим в Б непустое конечное 
подмножество РслБ имен примитивных или первич- 
ных схем. 

Элементы множества А используются для фор- 
мирования (имен) объектов. Связь объекта а с не- 
которой схемой 5 отражается записью Я а). Рели 
объект а связан со схемой 5 и 5еР, стандартная за- 
пись б'( а) заменяется записью я' либо а, когда ссы- 
лка на схему не важна или очевидна из контекста. 

Определение 2. Выражение вида 

/•я ь ...,я„->я 0 , (1) 

где я,еА, /=0,...,и - имена объектов, называется 
функциональной связью (ФС). В записи (1)/еР - 
это имя ФС, а, - ее аргументы (і = 1,...,л), я 0 - ре- 
зультат. 

Имена объектов при моделировании приклад- 
ной предметной области (ПО) формируются следу- 
ющим образом. 

Определение 3. Пусть яе А,ст - имя объекта, тог- 
да а, су. а и а. а также являются именами. В записи 
а. а а называется префиксом. Длина имени а опре- 
деляется числом вхождений элементов А (с учетом 
возможных повторений). 

Функциональные связи используются при зада- 
нии (непервичных) схем объектов моделируемой ПО. 
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Определение 4. Схема 5 объекта г определяется 
выражением вида 

5(/ ) = т.(5 01 (йг 01 8 0м /а 0К /), 

Рі^ 8 и (а п ),...,8 щ (а щ р..П (2) 

Р к =^і (%)>-> Л\ Мег), 

где 5еВ\Е, ге А. Для всех возможных значений ин- 
дексов і, ], 8 и е Б - собственные подсхемы схемы 5, 
а ѵ е А - ее собственные величины, д еР - выбираю- 
щие селекторы. В правой части (2) г называется пре- 
фиксом схемы, участок до вертикальной черты - за- 
головком, фрагмент І/.../І - вариантной его частью, а 
остальная часть заголовка - постоянной частью. Ие- 
роглиф /іііег скрывает список собственных ФС схемы 
5. Префикс г может «проноситься» в скобочный 
фрагмент, так что г.(8(а),...)^(г.8(а),...)^(8(г.а),...). 
Аналогичным образом префиксируются имена се- 
лекторов и отображений, а также имена величин, 
вовлеченных в формирование ФС из /іііег. 

Селекторы на интерпретации I получают истин- 
ностные (шкальные) значения и образуют полную 
систему, т. е. Ѵ/'ф Щ, д|,&д|,=Л и р ] |,ѵ...ѵ/4=И. 

Определение 5. Пусть 8(г)=(...8 1 /г.а, і )...) - схема. 
Если 8^е Е, то г.а у - имя величины схемы 5. Если 
фе 0\Е и а - имя величины схемы 8 Р то г.а Р а — 
имя величины схемы А Величины схемы 5 будем 
также называть её атрибутами. 

Определение 6. Рассмотрим схему А. ФС 
а„— ы 0 из /іііег называется допустимой для схе- 
мы 8, если и только если а р а ь ...,а„ - атрибуты схе- 
мы 5. Схема называется синтаксически правиль- 
ной, если /іііег содержит только допустимые ФС. 

В дальнейшем рассматриваются только синтак- 
сически правильные схемы. Помимо этого считает- 
ся, что ФС из набора /іііег, отвечают следующим тре- 
бованиям: (а) ФС содержит по крайней мере один 
собственный атрибут схемы; (б) в наборе /іііег нет 
ФС, в которые вовлечены атрибуты из разных ве- 
твей вариантной части схемы А или атрибуты из ва- 
риантных частей её подсхем ; (в) длина любого атри- 
бута (имени), входящего в ФС, не превышает двух. 

С каждым атрибутом связывается условие допу- 
стимости его существования в схеме. 

Определение 7. Факт наличия условия р у атри- 
бута а отмечается записью а/р, при этом а/р назы- 
вается у-атрибутом. Считается, что с атрибутами, 
определёнными в общей части заголовка схемы, 
связывается условие И, - в этом случае фрагмент 
«/р» опускается. 

Определение 8. Структурной (С-) моделью называ- 
ется конечная совокупность (описаний) схем 
М=(8 ]г ..,8 т ), где каждая 8 Ь і=1,...,п, является элемен- 
тарной или задана в соответствие с определением 4. 
С-модель Заявляется (синтаксически) замкнутой, если 
и только если для каждого её элемента 8,еМ схемы, 
встречающиеся в определении являются элементар- 
ными либо определены в описании С-модели М. 


Описывая С-модель для предметной области, 
мы строим специальную (формальную) теорию, в 
которой можно решать, в частности, задачу устано- 
вления выводимости предложений соответствую- 
щего языка и генерации реализующей вывод про- 
граммы. 

Постановка задачи в С-модели носит непроце- 
дурный характер - в ней указываются лишь исход- 
ные и искомые атрибуты некоторой схемы. Содер- 
жательно, постановка задачи на модели есть зада- 
ние на построение схемы алгоритма, реализующе- 
го требуемые вычисления. Схема алгоритма извле- 
кается из (конструктивного) доказательства соот- 
ветствующей теоремы существования (в силе [7]). 
Схема становится алгоритмом (программой) в ре- 
зультате задания интерпретации модели. 

Определение 9. Задачей в С-модели М называет- 
ся тройка Т^ОФДо.А), где Д, и Х й - наборы имён, 
соответственно, исходных и искомых величин, а 5” 
- схема С-модели М, в которой определены эти 
имена. 

При исследовании свойств С-моделей и алго- 
ритмов установления выводимости в них потребу- 
ется понятие развёртки схемы 8. 

Определение 10. Пусть 8(г)=г.(...8/а,/),...\/іІ1ег) - 
схема, и 8уё Е. Развёрткой 5” на атрибуте а называ- 
ется выражение, получающееся в результате: (а) 
подстановки в заголовок исходной схемы на место 
8/Оу) заголовка схемы Д и (б) присоединения к 
набору /іііег схемы А ФС схемы 8 Р Все добавленные 
в схему А в результате такого действия атрибуты, 
имена селекторов и отображений модифицируют- 
ся префиксом па Р Под полной развёрткой А С-мо- 
дели понимается объект, полученный из схемы А, у 
которой в результате последовательности развёр- 
ток на атрибутах в заголовке остаются только атри- 
буты, связанные с элементарными схемами. 

Понятие схемы нетрудно переопределить с тем, 
чтобы оно оставалось корректным для развёртки 
на атрибуте и полной развёртки. При построении 
С-модели допускаются возможность рекурсивных 
определений схем. В общем случае рекурсивная 
конструкция должна содержать, по меньшей мере, 
одну цепочку определений вида 5 , 1 =(...[5’ 2 ]...), 
8 1 =(...[8 г ]...),...,8 к =(...[8 1 ]...), обеспечивающую уча- 
стие в дефиниции некоторого понятия ссылки на 
себя. Ясно, что для рекурсивной схемы полная раз- 
вертка не определенна. 

2. Интерпретация С-модели и исчисление 5Я 

Интерпретация (семантика) С-модели вводится 
стандартным образом. 

Определение 11. Интерпретация I С-модели М 
задаёт: (а) для каждой элементарной схемы 5еЕ не- 
пустое множество (первичный тип) А|і; (б) для каж- 
дого функционального символа /еР - отображение 
/| І :5 1 | І х...х5„| І ->А 0 | І ; (в) для каждого селектора ре? - 
булевское отображение р | І :*5 , 1 [ І х...х,5 , „| І — >{И,Л}. 
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В результате задания интерпретации каждой не- 
элементарной схеме сопоставляется отношение, 
т. е. множество наборов, удовлетворяющих некото- 
рым условиям. Наборы принадлежат декартову 
произведению множеств, сопоставленных подсхе- 
мам схемы 5. Элементы наборов поименованы ат- 
рибутами заголовка. Если в заголовке схемы при- 
сутствует альтернативная часть, то наборы отноше- 
ния выбираются из размеченного декартова произ- 
ведения [8]. Разметку определяют селекторы аль- 
тернативной части. Термин «тип атрибута» служит 
сокращением для выражения «множество, сопо- 
ставленное схеме, с которым связан атрибут». В от- 
личие от первичного типа такой тип мы будем назы- 
вать ( непервичным или просто) типом, наборы типа 
- кортежами, а их именованные элементы - ком- 
понентами. 

Отображения, которые сопоставляются ФС 
схемы в результате задания семантики С-модели, 
определяют соотношения между компонентами 
кортежей. Выполнение этих соотношений указы- 
вает принадлежность кортежа типу. С компонента- 
ми кортежей связываются реализации условий, ко- 
торые приписаны соответствующим этим компо- 
нентам у-атрибутам. 

Для удобства и большей компактности рассуж- 
дений вводится ряд дополнительных соглашений, 
не имеющих принципиального характера: 

Используется только двухальтернативная фор- 
ма вариантной части в (2): і/р з...;...Д 

Вводится понятие предложения вычислимости 
(ПВ) вида Р:А->Х, служащее сокращением для 
{іуД— юс,}, где Р хі - определяемые ниже програм- 
мные термы, формирующие Р, а А^и{х,}. 

Определение 12. Рассмотрим С-модель 
М=(..Х..). Пусть а ] /р ] ,...,а„/р п , - у-атри- 

буты развёртки 5, Ц>-Ра 1 /р ь ...,а„Ір„-^х х ^ ь ...,х т ^ т - 
предложение вычислимости, а г - кортеж, опреде- 
ляемый заголовком развёртки при некоторой интер- 
претации I. Будем говорить, что Ф|, имеет смысл для 
кортежа г, если р\і=Ѵ\, і=\,...,п и ^||=И,у—1,...,/и. 

Определение 13. Будем говорить, что ПВ 
'Ѵ-РА-^-Х удовлетворяет схеме 5, если при любой 
интерпретации I тип 5|[ не содержит двух кортежей, 
для которых Ѵ Р|, имеет смысл, таких что их компо- 
ненты совпадают для всех атрибутов множества А, 
но не совпадают по крайней мере для одного атри- 
бута множества X. При этом для произвольного 
кортежа г, который принадлежит отношению 5|,, 
результатом применения Р[ к компонентам г, име- 
нованным атрибутами множества А, является набор 
компонент, именованных атрибутами множества X. 
Все ФС схемы удовлетворяют ей по определению. 

В исчислении имеется три сорта термов. 

Определение 14. (1) Термы первого сорта (а-тер- 
мы) представляют собой упорядоченные списки ат- 
рибутов, имена которых строятся из элементов А. 


(2) Термы второго сорта (у-термы) строятся из тер- 
мов первого сорта и селекторных символов, при- 
надлежащих множеству Р, согласно следующей ре- 
курсивной процедуре. Пусть р (п> е Р - селектор, реа- 
лизуемый «-местной булевской функцией, А - 
и-элементный терм первого сорта, такой, что его і - й 
атрибут связан с той же схемой, что и /- й аргумент р\ 
Р и 0 - термы второго сорта; а — некоторый атри- 
бут; «-» и «&» - символы отрицания и конъюнк- 
ции, соответственно. Тогда перечисленные выраже- 
ния являются термами второго сорта (других тер- 
мов второго сорта нет): а.р(А), -Р, Р&0. (3) Нако- 
нец, программные (пр-) термы третьего сорта стро- 
ятся из термов всех сортов по следующим прави- 
лам. Пусть Р - терм второго сорта; /,§, к - функ- 
циональные символы (элементы множества Р); Р ь 
Р ъ і 7 , - термы третьего сорта и имеются вхождения 
символа § в Ру, а - некоторый атрибут; Р 2 [к/§] - 
обозначение замены вхождения § на к в терме і 7 ,. 
Тогда а.к: - терм третьего сорта; Р х ;Р г - терм, 
построенный с применением оператора компози- 
ции; і/Рікеп Р\ еізе Р 2 /і- терм (оператор ветвления); 
к=і/ Р (кеп Ру еізе Р 2 [к/§] /? — терм (оператор рекур- 
сии). - Других термов третьего сорта нет. 

В рамках введенных соглашений используется 
базовый набор правил вывода: 

(0) схема аксиом : 'Л.Ѵ.ѵІ >,-І. 

(1) ^ (правило сужения)', 

РГ:А-+Х 

\~Р:А-^Х,2/Р \-/'2^>х/р , 

(2) — правило композиции), 

К Р;/:А2/Р^Х 2, х/Р&р 

здесь Р - конъюнкция (шкальных) условий дости- 
жимости атрибутов из X, а р - условие допустимо- 
сти х (условие достижимости - это условие, при 
котором в процессе построения доказательства 
обеспечивается достижимость некоторого атрибу- 
та, а условие допустимости - это условие, при ко- 
тором атрибут имеет смысл в описании). 

^ ^ ^ НРі -.А—>Х х/ <2& р РР 2 А—>Х х/<2& -р 
Н/ рікеп Г іеізе Р 2 /і А — >Х, х/() 

(правило ветвления)', 

(4) РГѵ.А-^Хх/(2&р 

ус п\(А)-+п^(Х\.., 8 ^(А)^(Х) V- Рі.А—>Х, х/<д&-р 

к=ір р ікепРі еѣе Т 7 2 [/г/^і ]...[/*/,§■.<] рі'А— >Х/(2 
(правило рекурсии). 

Построенное исчисление будем называть исчи- 
слением 8 Я (зігисіигед гесигзіѵе саісиіш). 

Для исчисления 8 К справедливы следующие 
утверждения. 

Теорема 1. Исчисление 8 К является коррект- 
ным относительно понятия ПВ, удовлетворяющего 
схеме А 

Теорема 2. Исчисление 8К является полным от- 
носительно понятия ПВ, удовлетворяющего схеме А 
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3. Стратегия и алгоритм установления выводимости 
предложений 5/? 

Алгоритм, включающий и стратегию вывода, 
описывается с использованием некоторого псевдо- 
кода, структуры управления которого традицион- 
ны для императивных языков программирования. 
При описании алгоритма используются следую- 
щие обозначения: 

• С к - множество у-атрибутов (развертки) исход- 
ной схемы, достижимость которых установлена 
на текущий момент; 

• ио-аксиома - проблемно-ориентированная или 
предметная аксиома - ФС из текущей схемы; 

• «вход в подсхему» - наличие в С к у-атрибутов, 
которые принадлежат подсхеме текущей схемы; 

• А 0 и А берутся из формулировки задачи Т. 

Описание алгоритма: 

«установить /=0, С 0 =Д)»; 

«поднять флаг «продолжать доказательство»»', 
«текущей схемой объявить 5»; 
уѵкііе «поднят флаг «продолжатъ доказатель- 
ство»» до і/ «имеется ио-аксиома текущей схе- 
мы, аргументы которой входят в С,» ікеп «при- 
менить правило композиции, и, если возмож- 
но, правило ветвления»; 

«построить С м : к С, добавить новые у-атрибуты 
либо изменить условия достижимости ранее по- 
лученных»; 

«установить /=/+1»; 

«если определился вход в подсхему, запомнить 
её в стеке»; 

еізе і/ «имеется подсхема, в которую определён 
вход» ікеп «объявить её текущей схемой»; 
еіае і/ «текущая - рекурсивная схема» ікеп 

«применить правило введения рекурсии; уста- 
новить /=/+1»; 

«определить С ж »; 

еіае «объявить текущей внешнюю схему»; 

лт 

і/ «текущая - исходная и нет ио-аксиом, аргу- 
менты которых входят в С, « ікеп «опустить флаг 
«продолжатъ доказательство »» од. 

Для приведенного алгоритма справедлива сле- 
дующая теорема. 

Теорема 3. Приведённый алгоритм корректен, 
т. е. обеспечивает нахождение всех выводимых ат- 
рибутов. Верхней оценкой сложности алгоритма 
является выражение 0(\М\ г ). 

4. Особенности введения рекурсии 

Для того чтобы рассмотреть особенности введе- 
ния правила рекурсии дадим определение замыка- 
ния. 


Определение 15. Пусть 8(г) = г.(А,Х. ... /іііег) и 
пусть А - некоторый набор атрибутов схемы 5. За- 
мыканием А + для А относительно 5 будем называть 
объединение всех таких атрибутов X, что ПВ 
Р.А->Х может быть получено с использованием 
правил 8К из информации о схеме 8. 

Теперь предположим, что мы имеем рекурсив- 
ную детерминированную схему 8(а)=а.(А,...і/ 
/о...; 8(ѵ),.../і Ціііег). Пусть, для простоты, все под- 
схемы за исключением 8 являются элементарны- 
ми. По сделанному предположению схема 8 стала 
текущей с «входом», определяемым множеством А. 

Введем следующие обозначения Аг§ и Кез - 
множество аргументов и результатов рекурсивного 
ПВ соответственно; 

Опишем на содержательном уровне процесс, 
который позволяет определить Аг§ и Ке$ из заклю- 
чения правила введения рекурсии. Сначала, не 
применяя правила (4) исчисления ЗДдля схемы 8, 
выводим из атрибутов А всё, что возможно. В Аг§ 
включаем все входные атрибуты А. Для этих атри- 
бутов показана достижимость при условии, кото- 
рое приписано постоянной части схемы 8 (условие 
«входа» в 5). После этого определяем замыкание А + 
и объявляем его окончательным множеством аргу- 
ментов Аг§. 

В Яе$ помешаем у-атрибуты из постоянной ча- 
сти схемы А не попадающие в Аг§, для которых по- 
казана достижимость от Аг§ при условии нерекур- 
сивной ветви, и такие, что вовлечены в левые части 
ФС вида а./:...,а.ѵ.Ь,...-^а.с - «выводящие» из ре- 
курсивного вхождения схемы а.8(ѵ). Наконец, 
транзитивное замыкание полученного множества 
атрибутов Де8 + объявляем окончательным множе- 
ством результатов рекурсивного ПВ. 

Замечание 1. Если любое из транзитивных за- 
мыканий окажется пустым, применение правила 
введения рекурсии оказывается невозможным. 

Замечание 2. Если транзитивное замыкание 
строить без учета дополнительных соображений, 
затраты времени могут стать экспоненциальными 
по числу атрибутов. 

Заключение 

Как показывает практика, стратегия, обеспечи- 
ваемая теорией С-моделей в комплексе с исчисле- 
нием 8К допускает весьма эффективные реализа- 
ции разнообразных когнитивных систем. В силу 
того, что задача установления выводимости тесно 
связана с нахождением транзитивных замыканий 
специальных отношений, естественные варианты 
реализации опираются на прекрасно зарекомендо- 
вавшие себя и весьма эффективные подходы. 
Прежде всего, среди последних имеет смысл выде- 
лить алгоритмы Армстронга и ДиковскогоЦО]. В 
разных модификациях эти алгоритмы обладают 
полиномиальными оценками с невысокими степе- 
нями (линейные либо квадратичные), хотя и связа- 
ны с существенно более бедными по сравнению с 
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описываемыми здесь моделями. В первом случае 
речь идет о связях на атрибутах реляционных схем 
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